<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.5"/>
<title>xilskey: xilskey_bbram_ultrascale_input.h File Reference</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript">
  $(document).ready(initResizable);
  $(window).load(resizeHeight);
</script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
<link href="HTML_custom.css" rel="stylesheet" type="text/css"/>
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
 <tbody>
 <tr style="height: 56px;">
  <td id="projectlogo"><img alt="Logo" src="xlogo_bg.png"/></td>
  <td style="padding-left: 0.5em;">
   <div id="projectname">xilskey
   </div>
   <div id="projectbrief">Vitis Drivers API Documentation</div>
  </td>
 </tr>
 </tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.5 -->
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="index.html"><span>Overview</span></a></li>
      <li><a href="annotated.html"><span>Data&#160;Structures</span></a></li>
      <li><a href="globals.html"><span>APIs</span></a></li>
      <li><a href="files.html"><span>File&#160;List</span></a></li>
    </ul>
  </div>
</div><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
  <div id="nav-tree">
    <div id="nav-tree-contents">
      <div id="nav-sync" class="sync"></div>
    </div>
  </div>
  <div id="splitbar" style="-moz-user-select:none;"
       class="ui-resizable-handle">
  </div>
</div>
<script type="text/javascript">
$(document).ready(function(){initNavTree('xilskey__bbram__ultrascale__input_8h.html','');});
</script>
<div id="doc-content">
<div class="header">
  <div class="summary">
<a href="#define-members">Macros</a>  </div>
  <div class="headertitle">
<div class="title">xilskey_bbram_ultrascale_input.h File Reference</div>  </div>
</div><!--header-->
<div class="contents">
<a name="details" id="details"></a><h2 class="groupheader">Overview</h2>
<div class="textblock"><p>This file contains macros which needs to configured by user based on the options selected by user operations will be performed. </p>
<dl class="section note"><dt>Note</dt><dd><pre class="fragment">            User configurable parameters for Ultrascale BBRAM
    ----------------------------------------------------------------------
  #define XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_0           FALSE
  TRUE will program BBRAM with OBFUSCATED key provided in
  XSK_BBRAM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_0. While programming obfuscated key DPA
  configurations cannot be done due to silicon bug, and values provided
  in DPA configuration macros will be ignored.
  FALSE will program the BBRAM with key provided in XSK_BBRAM_AES_KEY_SLR_CONFIG_ORDER_0
  and DPA configurations (protect, count and mode) can be configured

  #define XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_1           FALSE
  TRUE will program BBRAM with OBFUSCATED key provided in
  XSK_BBRAM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_1. While programming obfuscated key DPA
  configurations cannot be done due to silicon bug, and values provided
  in DPA configuration macros will be ignored.
  FALSE will program the BBRAM with key provided in XSK_BBRAM_AES_KEY_SLR_CONFIG_ORDER_1
  and DPA configurations (protect, count and mode) can be configured

  #define XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_2           FALSE
  TRUE will program BBRAM with OBFUSCATED key provided in
  XSK_BBRAM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_2. While programming obfuscated key DPA
  configurations cannot be done due to silicon bug, and values provided
  in DPA configuration macros will be ignored.
  FALSE will program the BBRAM with key provided in XSK_BBRAM_AES_KEY_SLR_CONFIG_ORDER_2
  and DPA configurations (protect, count and mode) can be configured

  #define XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_3           FALSE
  TRUE will program BBRAM with OBFUSCATED key provided in
  XSK_BBRAM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_3. While programming obfuscated key DPA
  configurations cannot be done due to silicon bug, and values provided
  in DPA configuration macros will be ignored.
  FALSE will program the BBRAM with key provided in XSK_BBRAM_AES_KEY_SLR_CONFIG_ORDER_3
  and DPA configurations (protect, count and mode) can be configured

  #define           XSK_BBRAM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_0
  "b1c276899d71fb4cdd4a0a7905ea46c2e11f9574d09c7ea23b70b67de713ccd1"
  The value mentioned in this will be converted to hex buffer and the
  key is programmed into BBRAM, when program API used. It should be 64
  characters long, valid characters are 0-9,a-f,A-F. Any other character
  is considered as invalid string and will not program BBRAM. Note that,
  for writing the OBFUSCATED Key, XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_0 should
  have TRUE value.

  #define           XSK_BBRAM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_1
  "b1c276899d71fb4cdd4a0a7905ea46c2e11f9574d09c7ea23b70b67de713ccd1"
  The value mentioned in this will be converted to hex buffer and the
  key is programmed into BBRAM, when program API used. It should be 64
  characters long, valid characters are 0-9,a-f,A-F. Any other character
  is considered as invalid string and will not program BBRAM. Note that,
  for writing the OBFUSCATED Key, XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_1 should
  have TRUE value.

  #define           XSK_BBRAM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_2
  "b1c276899d71fb4cdd4a0a7905ea46c2e11f9574d09c7ea23b70b67de713ccd1"
  The value mentioned in this will be converted to hex buffer and the
  key is programmed into BBRAM, when program API used. It should be 64
  characters long, valid characters are 0-9,a-f,A-F. Any other character
  is considered as invalid string and will not program BBRAM. Note that,
  for writing the OBFUSCATED Key, XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_2 should
  have TRUE value.

  #define           XSK_BBRAM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_3
  "b1c276899d71fb4cdd4a0a7905ea46c2e11f9574d09c7ea23b70b67de713ccd1"
  The value mentioned in this will be converted to hex buffer and the
  key is programmed into BBRAM, when program API used. It should be 64
  characters long, valid characters are 0-9,a-f,A-F. Any other character
  is considered as invalid string and will not program BBRAM. Note that,
  for writing the OBFUSCATED Key, XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_3 should
  have TRUE value.

  #define XSK_BBRAM_PGM_AES_KEY_SLR_CONFIG_ORDER_0                  FALSE
  #define XSK_BBRAM_PGM_AES_KEY_SLR_CONFIG_ORDER_1                  FALSE
  #define XSK_BBRAM_PGM_AES_KEY_SLR_CONFIG_ORDER_2                  FALSE
  #define XSK_BBRAM_PGM_AES_KEY_SLR_CONFIG_ORDER_3                  FALSE
  TRUE will program BBRAM with AES Key provided in XSK_BBRAM_AES_KEY for
  particular SLR.

    #define         XSK_BBRAM_AES_KEY_SLR_CONFIG_ORDER_0
  "349de4571ae6d88de23de65489acf67000ff5ec901ae3d409aabbce4549812dd"
  #define   XSK_BBRAM_AES_KEY_SLR_CONFIG_ORDER_1
  "349de4571ae6d88de23de65489acf67000ff5ec901ae3d409aabbce4549812dd"
  #define   XSK_BBRAM_AES_KEY_SLR_CONFIG_ORDER_2
  "349de4571ae6d88de23de65489acf67000ff5ec901ae3d409aabbce4549812dd"
  #define   XSK_BBRAM_AES_KEY_SLR_CONFIG_ORDER_3
  "349de4571ae6d88de23de65489acf67000ff5ec901ae3d409aabbce4549812dd"
  The value mentioned in this will be converted to hex buffer and the
  key is programmed into BBRAM for particular SLR(1/2/3/4), when
  program API used. It should be 64 characters long, valid characters
  are 0-9,a-f,A-F. Any other character is considered as invalid string
  and will not program BBRAM. Note that, for writing the BBRAM Key, XSK_
  BBRAM_PGM_OBFUSCATED_KEY for particular SLR(1/2/3/4)should have FALSE value.

    #define XSK_BBRAM_AES_KEY_SIZE_IN_BITS  256

  #define XSK_BBRAM_DPA_PROTECT_ENABLE      FALSE
  TRUE will enable the DPA protection for BBRAM key, to enable
  DPA protection XSK_BBRAM_PGM_OBFUSCATED_KEY should be FALSE,
  as DPA protection is not supported for Obfuscated key due to silicon
  bug, XSK_BBRAM_DPA_COUNT should be in the range of 1-255 and
  XSK_BBRAM_DPA_MODE can be XSK_BBRAM_INVALID_CONFIGURATIONS or
  XSK_BBRAM_ALL_CONFIGURATIONS.
  FALSE will not enable DPA protection, XSK_BBRAM_DPA_COUNT and
  XSK_BBRAM_DPA_MODE both will be taken default values 0 and
  XSK_BBRAM_INVALID_CONFIGURATIONS respectively

  #define XSK_BBRAM_DPA_COUNT       0
  Default value will be zero,
  when XSK_BBRAM_DPA_PROTECT_ENABLE is TRUE this should be in range
  of 1-255 (should be greater that zero).

  #define XSK_BBRAM_DPA_MODE        XSK_BBRAM_INVALID_CONFIGURATIONS
  Default value is XSK_BBRAM_INVALID_CONFIGURATIONS
  When XSK_BBRAM_DPA_PROTECT_ENABLE is TRUE it can be
  XSK_BBRAM_INVALID_CONFIGURATIONS or XSK_BBRAM_ALL_CONFIGURATIONS
  If XSK_BBRAM_DPA_PROTECT_ENABLE is FALSE, it should be
  XSK_BBRAM_INVALID_CONFIGURATIONS.

  #define XSK_BBRAM_AXI_GPIO_DEVICE_ID  XPAR_AXI_GPIO_0_DEVICE_ID
  Default value is XPAR_AXI_GPIO_0_DEVICE_ID
  This macro is for providing exact GPIO device ID, based on the
  design configuration this macro should be modified to provide
  GPIO device ID which is used for connecting MASTER JTAG pins.

  In Ultrascale GPIO pins are used for connecting MASTER_JTAG pins to
  access BBRAM.
  Following are the GPIO pins and user can change these pins
  #define XSK_BBRAM_AXI_GPIO_JTAG_TDO       (0)
  #define XSK_BBRAM_AXI_GPIO_JTAG_TDI       (0)
  #define XSK_BBRAM_AXI_GPIO_JTAG_TMS       (1)
  #define XSK_BBRAM_AXI_GPIO_JTAG_TCK       (2)

  #define XSK_BBRAM_GPIO_INPUT_CH           (2)
  This macro is for providing channel number of ALL INPUTS connected(TDO)
  #define XSK_BBRAM_GPIO_OUTPUT_CH  (1)
  This macro is for providing channel number of ALL OUTPUTS connected
  (TDI, TCK, TMS)

  NOTE: All inputs and outputs of GPIO can be configured in single
  channel also
  i.e XSK_BBRAM_GPIO_INPUT_CH = XSK_BBRAM_GPIO_OUTPUT_CH = 1 or 2.
  Among (TDI, TCK, TMS) Outputs of GPIO cannot be connected to different
  GPIO channels all the 3 signals should be in same channel.
  TDO can be a other channel of (TDI, TCK, TMS) or the same.
  DPA protection can be enabled only when programming non-obfuscated key.
</pre></dd></dl>
<pre>
MODIFICATION HISTORY:</pre><pre>Ver   Who     Date     Changes
</p>
<hr/>
<p>
5.0   vns     09/01/16 First Release.
6.0   vns     07/28/16 Added counting configuration
                       feature(DPA count), protection and to
                       program Obfuscated key.
6.7   psl     03/20/19 Added BBRAM key write support for SSIT devices.
      psl     03/29/19 Added Support for user configurable GPIO for
                       jtag control.
7.5   ng      07/13/23 added SDT support
      ng      09/02/23 fixed gpio macro in SDT flow
</pre> </div><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="define-members"></a>
Macros</h2></td></tr>
<tr class="memitem:a427028c2b5a515f626acdb95dfa78b1f"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#a427028c2b5a515f626acdb95dfa78b1f">XSK_BBRAM_AXI_GPIO_DEVICE_ID</a>&#160;&#160;&#160;XPAR_AXI_GPIO_0_DEVICE_ID</td></tr>
<tr class="memdesc:a427028c2b5a515f626acdb95dfa78b1f"><td class="mdescLeft">&#160;</td><td class="mdescRight">Following defines should be given in decimal/hexa-decimal values.  <a href="#a427028c2b5a515f626acdb95dfa78b1f">More...</a><br/></td></tr>
<tr class="separator:a427028c2b5a515f626acdb95dfa78b1f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac73d040616b9bbc20b49414ac6fd82d2"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#ac73d040616b9bbc20b49414ac6fd82d2">XSK_BBRAM_AXI_GPIO_JTAG_TDO</a>&#160;&#160;&#160;(0)</td></tr>
<tr class="memdesc:ac73d040616b9bbc20b49414ac6fd82d2"><td class="mdescLeft">&#160;</td><td class="mdescRight">MASTER JTAG GPIO pin for TDO.  <a href="#ac73d040616b9bbc20b49414ac6fd82d2">More...</a><br/></td></tr>
<tr class="separator:ac73d040616b9bbc20b49414ac6fd82d2"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a9d56ab45b292fba5378800f2213bd0df"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#a9d56ab45b292fba5378800f2213bd0df">XSK_BBRAM_AXI_GPIO_JTAG_TDI</a>&#160;&#160;&#160;(0)</td></tr>
<tr class="memdesc:a9d56ab45b292fba5378800f2213bd0df"><td class="mdescLeft">&#160;</td><td class="mdescRight">MASTER JTAG GPIO pin for TDI.  <a href="#a9d56ab45b292fba5378800f2213bd0df">More...</a><br/></td></tr>
<tr class="separator:a9d56ab45b292fba5378800f2213bd0df"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a61a94a82a5ff1ba3012601dcffdf14c7"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#a61a94a82a5ff1ba3012601dcffdf14c7">XSK_BBRAM_AXI_GPIO_JTAG_TMS</a>&#160;&#160;&#160;(1)</td></tr>
<tr class="memdesc:a61a94a82a5ff1ba3012601dcffdf14c7"><td class="mdescLeft">&#160;</td><td class="mdescRight">MASTER JTAG GPIO pin for TMS.  <a href="#a61a94a82a5ff1ba3012601dcffdf14c7">More...</a><br/></td></tr>
<tr class="separator:a61a94a82a5ff1ba3012601dcffdf14c7"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac260766db5e90f3705c1dac416ba5e7b"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#ac260766db5e90f3705c1dac416ba5e7b">XSK_BBRAM_AXI_GPIO_JTAG_TCK</a>&#160;&#160;&#160;(2)</td></tr>
<tr class="memdesc:ac260766db5e90f3705c1dac416ba5e7b"><td class="mdescLeft">&#160;</td><td class="mdescRight">MASTER JTAG GPIO pin for TCK.  <a href="#ac260766db5e90f3705c1dac416ba5e7b">More...</a><br/></td></tr>
<tr class="separator:ac260766db5e90f3705c1dac416ba5e7b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a2c8a163c89e4885dc920fc67394ee4f1"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#a2c8a163c89e4885dc920fc67394ee4f1">XSK_BBRAM_GPIO_INPUT_CH</a>&#160;&#160;&#160;(2)</td></tr>
<tr class="memdesc:a2c8a163c89e4885dc920fc67394ee4f1"><td class="mdescLeft">&#160;</td><td class="mdescRight">GPIO Channel of TDO pin connected.  <a href="#a2c8a163c89e4885dc920fc67394ee4f1">More...</a><br/></td></tr>
<tr class="separator:a2c8a163c89e4885dc920fc67394ee4f1"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ac421d8cdc6bfcbdc399b473939688379"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#ac421d8cdc6bfcbdc399b473939688379">XSK_BBRAM_GPIO_OUTPUT_CH</a>&#160;&#160;&#160;(1)</td></tr>
<tr class="memdesc:ac421d8cdc6bfcbdc399b473939688379"><td class="mdescLeft">&#160;</td><td class="mdescRight">GPIO Channel of TDI, TMS and TCK pin connected.  <a href="#ac421d8cdc6bfcbdc399b473939688379">More...</a><br/></td></tr>
<tr class="separator:ac421d8cdc6bfcbdc399b473939688379"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ab51b32965cd87ce17c02b68dd50016da"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#ab51b32965cd87ce17c02b68dd50016da">XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_0</a>&#160;&#160;&#160;FALSE</td></tr>
<tr class="memdesc:ab51b32965cd87ce17c02b68dd50016da"><td class="mdescLeft">&#160;</td><td class="mdescRight">TRUE burns obfuscated key.  <a href="#ab51b32965cd87ce17c02b68dd50016da">More...</a><br/></td></tr>
<tr class="separator:ab51b32965cd87ce17c02b68dd50016da"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a0bb8e937f8c6eb96ecc4b1cfc0055029"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#a0bb8e937f8c6eb96ecc4b1cfc0055029">XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_1</a>&#160;&#160;&#160;FALSE</td></tr>
<tr class="memdesc:a0bb8e937f8c6eb96ecc4b1cfc0055029"><td class="mdescLeft">&#160;</td><td class="mdescRight">TRUE burns obfuscated key.  <a href="#a0bb8e937f8c6eb96ecc4b1cfc0055029">More...</a><br/></td></tr>
<tr class="separator:a0bb8e937f8c6eb96ecc4b1cfc0055029"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aaca7038d7ac493408e7d8eabc7bcc885"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#aaca7038d7ac493408e7d8eabc7bcc885">XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_2</a>&#160;&#160;&#160;FALSE</td></tr>
<tr class="memdesc:aaca7038d7ac493408e7d8eabc7bcc885"><td class="mdescLeft">&#160;</td><td class="mdescRight">TRUE burns obfuscated key.  <a href="#aaca7038d7ac493408e7d8eabc7bcc885">More...</a><br/></td></tr>
<tr class="separator:aaca7038d7ac493408e7d8eabc7bcc885"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a55b4bf8197a3ce4ba6dd59a1b30c1fd0"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#a55b4bf8197a3ce4ba6dd59a1b30c1fd0">XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_3</a>&#160;&#160;&#160;FALSE</td></tr>
<tr class="memdesc:a55b4bf8197a3ce4ba6dd59a1b30c1fd0"><td class="mdescLeft">&#160;</td><td class="mdescRight">TRUE burns obfuscated key.  <a href="#a55b4bf8197a3ce4ba6dd59a1b30c1fd0">More...</a><br/></td></tr>
<tr class="separator:a55b4bf8197a3ce4ba6dd59a1b30c1fd0"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a33abdcfb449aff3bd99ebfe4167805b5"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#a33abdcfb449aff3bd99ebfe4167805b5">XSK_BBRAM_PGM_AES_KEY_SLR_CONFIG_ORDER_0</a>&#160;&#160;&#160;FALSE</td></tr>
<tr class="memdesc:a33abdcfb449aff3bd99ebfe4167805b5"><td class="mdescLeft">&#160;</td><td class="mdescRight">If the following is TRUE BBRAM Key in corresponding XSK_BBRAM_AES_KEY_SLR_CONFIG_ORDER_INDEX is programmed Returns error if the target doesn't have enabled SLR.  <a href="#a33abdcfb449aff3bd99ebfe4167805b5">More...</a><br/></td></tr>
<tr class="separator:a33abdcfb449aff3bd99ebfe4167805b5"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:afcb4c08aaf1357459a0bab50ec1c0969"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#afcb4c08aaf1357459a0bab50ec1c0969">XSK_BBRAM_PGM_AES_KEY_SLR_CONFIG_ORDER_1</a>&#160;&#160;&#160;FALSE</td></tr>
<tr class="memdesc:afcb4c08aaf1357459a0bab50ec1c0969"><td class="mdescLeft">&#160;</td><td class="mdescRight">TRUE burns BBRAM key.  <a href="#afcb4c08aaf1357459a0bab50ec1c0969">More...</a><br/></td></tr>
<tr class="separator:afcb4c08aaf1357459a0bab50ec1c0969"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a509ab1e3b0950cf8b1fa39047c536ac4"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#a509ab1e3b0950cf8b1fa39047c536ac4">XSK_BBRAM_PGM_AES_KEY_SLR_CONFIG_ORDER_2</a>&#160;&#160;&#160;FALSE</td></tr>
<tr class="memdesc:a509ab1e3b0950cf8b1fa39047c536ac4"><td class="mdescLeft">&#160;</td><td class="mdescRight">TRUE burns BBRAM key.  <a href="#a509ab1e3b0950cf8b1fa39047c536ac4">More...</a><br/></td></tr>
<tr class="separator:a509ab1e3b0950cf8b1fa39047c536ac4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a87aa0c2ce592abc84a1e05b0d6c14205"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#a87aa0c2ce592abc84a1e05b0d6c14205">XSK_BBRAM_PGM_AES_KEY_SLR_CONFIG_ORDER_3</a>&#160;&#160;&#160;FALSE</td></tr>
<tr class="memdesc:a87aa0c2ce592abc84a1e05b0d6c14205"><td class="mdescLeft">&#160;</td><td class="mdescRight">TRUE burns BBRAM key.  <a href="#a87aa0c2ce592abc84a1e05b0d6c14205">More...</a><br/></td></tr>
<tr class="separator:a87aa0c2ce592abc84a1e05b0d6c14205"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad7051b5ff22bacaeb91d3f0f0b81b861"><td class="memItemLeft" align="right" valign="top">#define&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="xilskey__bbram__ultrascale__input_8h.html#ad7051b5ff22bacaeb91d3f0f0b81b861">XSK_BBRAM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_0</a>&#160;&#160;&#160;&quot;b1c276899d71fb4cdd4a0a7905ea46c2e11f9574d09c7ea23b70b67de713ccd1&quot;</td></tr>
<tr class="memdesc:ad7051b5ff22bacaeb91d3f0f0b81b861"><td class="mdescLeft">&#160;</td><td class="mdescRight">This is the 256 bit key to be programmed into BBRAM.  <a href="#ad7051b5ff22bacaeb91d3f0f0b81b861">More...</a><br/></td></tr>
<tr class="separator:ad7051b5ff22bacaeb91d3f0f0b81b861"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<h2 class="groupheader">Macro Definition Documentation</h2>
<a class="anchor" id="a427028c2b5a515f626acdb95dfa78b1f"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_AXI_GPIO_DEVICE_ID&#160;&#160;&#160;XPAR_AXI_GPIO_0_DEVICE_ID</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>Following defines should be given in decimal/hexa-decimal values. </p>
<p>These are to be defined for Ultrascale Microblaze AXI GPIO pin numbers connected to MASTER JTAG primitive and corresponding channel numbers for GPIO pins </p>

</div>
</div>
<a class="anchor" id="ac260766db5e90f3705c1dac416ba5e7b"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_AXI_GPIO_JTAG_TCK&#160;&#160;&#160;(2)</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>MASTER JTAG GPIO pin for TCK. </p>

</div>
</div>
<a class="anchor" id="a9d56ab45b292fba5378800f2213bd0df"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_AXI_GPIO_JTAG_TDI&#160;&#160;&#160;(0)</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>MASTER JTAG GPIO pin for TDI. </p>

</div>
</div>
<a class="anchor" id="ac73d040616b9bbc20b49414ac6fd82d2"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_AXI_GPIO_JTAG_TDO&#160;&#160;&#160;(0)</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>MASTER JTAG GPIO pin for TDO. </p>

</div>
</div>
<a class="anchor" id="a61a94a82a5ff1ba3012601dcffdf14c7"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_AXI_GPIO_JTAG_TMS&#160;&#160;&#160;(1)</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>MASTER JTAG GPIO pin for TMS. </p>

</div>
</div>
<a class="anchor" id="a2c8a163c89e4885dc920fc67394ee4f1"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_GPIO_INPUT_CH&#160;&#160;&#160;(2)</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>GPIO Channel of TDO pin connected. </p>

</div>
</div>
<a class="anchor" id="ac421d8cdc6bfcbdc399b473939688379"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_GPIO_OUTPUT_CH&#160;&#160;&#160;(1)</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>GPIO Channel of TDI, TMS and TCK pin connected. </p>

</div>
</div>
<a class="anchor" id="ad7051b5ff22bacaeb91d3f0f0b81b861"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_0&#160;&#160;&#160;&quot;b1c276899d71fb4cdd4a0a7905ea46c2e11f9574d09c7ea23b70b67de713ccd1&quot;</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>This is the 256 bit key to be programmed into BBRAM. </p>
<p>This should entered by user in HEX. </p>

<p>Referenced by <a class="el" href="xilskey__bbram__ultrascale__example_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4">main()</a>.</p>

</div>
</div>
<a class="anchor" id="a33abdcfb449aff3bd99ebfe4167805b5"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_PGM_AES_KEY_SLR_CONFIG_ORDER_0&#160;&#160;&#160;FALSE</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>If the following is TRUE BBRAM Key in corresponding XSK_BBRAM_AES_KEY_SLR_CONFIG_ORDER_INDEX is programmed Returns error if the target doesn't have enabled SLR. </p>
<p>TRUE burns BBRAM key </p>

<p>Referenced by <a class="el" href="xilskey__bbram__ultrascale__example_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4">main()</a>.</p>

</div>
</div>
<a class="anchor" id="afcb4c08aaf1357459a0bab50ec1c0969"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_PGM_AES_KEY_SLR_CONFIG_ORDER_1&#160;&#160;&#160;FALSE</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>TRUE burns BBRAM key. </p>

<p>Referenced by <a class="el" href="xilskey__bbram__ultrascale__example_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4">main()</a>.</p>

</div>
</div>
<a class="anchor" id="a509ab1e3b0950cf8b1fa39047c536ac4"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_PGM_AES_KEY_SLR_CONFIG_ORDER_2&#160;&#160;&#160;FALSE</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>TRUE burns BBRAM key. </p>

<p>Referenced by <a class="el" href="xilskey__bbram__ultrascale__example_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4">main()</a>.</p>

</div>
</div>
<a class="anchor" id="a87aa0c2ce592abc84a1e05b0d6c14205"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_PGM_AES_KEY_SLR_CONFIG_ORDER_3&#160;&#160;&#160;FALSE</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>TRUE burns BBRAM key. </p>

<p>Referenced by <a class="el" href="xilskey__bbram__ultrascale__example_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4">main()</a>.</p>

</div>
</div>
<a class="anchor" id="ab51b32965cd87ce17c02b68dd50016da"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_0&#160;&#160;&#160;FALSE</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>TRUE burns obfuscated key. </p>

<p>Referenced by <a class="el" href="xilskey__bbram__ultrascale__example_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4">main()</a>.</p>

</div>
</div>
<a class="anchor" id="a0bb8e937f8c6eb96ecc4b1cfc0055029"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_1&#160;&#160;&#160;FALSE</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>TRUE burns obfuscated key. </p>

<p>Referenced by <a class="el" href="xilskey__bbram__ultrascale__example_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4">main()</a>.</p>

</div>
</div>
<a class="anchor" id="aaca7038d7ac493408e7d8eabc7bcc885"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_2&#160;&#160;&#160;FALSE</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>TRUE burns obfuscated key. </p>

<p>Referenced by <a class="el" href="xilskey__bbram__ultrascale__example_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4">main()</a>.</p>

</div>
</div>
<a class="anchor" id="a55b4bf8197a3ce4ba6dd59a1b30c1fd0"></a>
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">#define XSK_BBRAM_PGM_OBFUSCATED_KEY_SLR_CONFIG_ORDER_3&#160;&#160;&#160;FALSE</td>
        </tr>
      </table>
</div><div class="memdoc">

<p>TRUE burns obfuscated key. </p>

<p>Referenced by <a class="el" href="xilskey__bbram__ultrascale__example_8c.html#ae66f6b31b5ad750f1fe042a706a4e3d4">main()</a>.</p>

</div>
</div>
</div><!-- contents -->
</div><!-- doc-content -->
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
	<p class="footer">&copy; Copyright 2015-2022 Xilinx, Inc. All Rights Reserved.</p>
	<p class="footer">&copy; Copyright 2022-2023 Advanced Micro Devices, Inc. All Rights Reserved.</p>
</div>
</body>
</html>
